December 29, 1999

W.K. Richardson 1859-1951

Attorney Docket No.: 07850-056001

### **Box Patent Application**

Assistant Commissioner for Patents Washington, DC 20231

Presented for filing is a new original patent application of:

Applicant: BIN CHI CHIOU

BOSTON

DELAWARE

NEW YORK

SILICON VALLEY SOUTHERN CALIFORNIA

TWIN CITIES

WASHINGTON, DC

Title: ETHERNET SWITCH AND METHOD OF SWITCHING

Enclosed are the following papers, including those required to receive a filing date under 37 CFR 1.53(b):

|               | Pages |
|---------------|-------|
| Specification | 21    |
| Claims        | 5     |
| Abstract      | 1     |
| Declaration   | 1     |
| Drawings      | 9     |

#### Enclosures:

- Assignment cover sheet and an assignment, 2 pages, and a separate \$40 fee.
- A certified copy of the priority application will be filed at a later date.
- Postcard.

CERTIFICATE OF MAILING BY EXPRESS MAIL

Express Mail Label No. EL245470027US

I hereby certify under 37 CFR §1 10 that this correspondence is being deposited with the United States Postal Service as Express Mail Post Office to Addressee with sufficient postage on the date indicated below and is addressed to the Assistant Commissioner for Patents, Washington, DC. 20231.

Date of Depo

Signature

Typed or Printed Name of Person Signing Certificate

# FISH & RICHARDSON P.C.

Assistant Commissioner for Patents December 29, 1999 Page 2

Under 35 USC 119, this application claims the benefit of a foreign priority application filed in Taiwan, serial number 87122010, filed December 31, 1998.

| Basic filing fee                             | \$690      |
|----------------------------------------------|------------|
| Total claims in excess of 20 times \$18      | \$0<br>\$0 |
| Independent claims in excess of 3 times \$78 | \$0<br>\$0 |
| Fee for multiple dependent claims            | \$0        |
| Total filing fee:                            | \$690      |

A check for the filing fee is enclosed. Please apply any other required fees or any credits to deposit account 06-1050, referencing the attorney docket number shown above.

If this application is found to be incomplete, or if a telephone conference would otherwise be helpful, please call the undersigned at (617) 542-5070.

Kindly acknowledge receipt of this application by returning the enclosed postcard.

Please send all correspondence to:

Frank R. Ochenti

FRANK R. OCCHIUTI Fish & Richardson P.C. 225 Franklin Street Boston, MA 02110-2804

Respectfully submitted,

Frank R. Occhiuti

Reg. No. 35,306

**Enclosures** 

/mgd 20013799 doc

# **APPLICATION**

# **FOR**

# UNITED STATES LETTERS PATENT

TITLE:

ETHERNET SWITCH AND METHOD OF SWITCHING

APPLICANT:

BIN CHI CHIOU

# CERTIFICATE OF MAILING BY EXPRESS MAIL

| Express Mail Label No. <u>EL245470027US</u>                                                                                                                                                                                                                                                      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I hereby certify under 37 CFR §1 10 that this correspondence is bein deposited with the United States Postal Service as Express Mail Po Office to Addressee with sufficient postage on the date indicated belo and is addressed to the Assistant Commissioner for Patents, Washington D.C 20231. |
| Date of Deposit December 29, 1999                                                                                                                                                                                                                                                                |
| Signature Some allo Rall                                                                                                                                                                                                                                                                         |

Typed or Printed Name of Person Signing Certificate

ũ

5

10

15

20

25

30

Client's ref.:87-188
File: 0492-2480Q/SUE/Final

#### TITLE

#### ETHERNET SWITCH AND METHOD OF SWITCHING

#### BACKGROUND OF THE INVENTION

#### Field of the Invention:

This invention relates to a network component, particularly to an Ethernet switch and its method of switching, for selectively transmitting data among several data ports or filtering network packets.

# Description of the Prior Art:

Ethernet is the most popular local area network (LAN) in digital communication market. Previously, the framework is a 10BASE5 bus topology network. 10BASE2 is a lower cost improvement of 10BASE5. Although 10BASE2 and 10BASE5 belong to the same bus topology network and operate at the same 10Mhz frequency, 10BASE2 uses a different type of coaxial cable, and its transmission distance is limited to 200 meters. Both 10BASE5 and 10BASE2 networks have the following drawbacks: costly installation, inflexible installation, and inability to use existing wiring system in the building, among others. 10BASE-T network has been proposed to make use of twisted cable to construct a star topology network for overcoming the drawbacks of 10BASE2 and 10BASE5 network.

When the scale of LAN grows larger and the load of digital transmission among LANs is also increases, the Ethernet performance degrades with the increasing number of nodes connected the LANs. Consequently, high speed Ethernet

10

15

20

25

30

Client's ref.:87-188
File: 0492-2480Q/SUE/Final

operating at high clock frequency is provided to address to the requirement for large-scale LANs or high speed digital terminals. High speed Ethernet operates at 100 MHz clock frequency to basically improve the performance of the 10BASE Ethernet. Moreover, high speed Ethernet also defines a media independent interface, for easy connection of said network nodes to twisted cable media or fiber optical mediabased networks, such as 100BASE-TX, 100BASE-T4, or 100BASE-FX networks.

Basically, 10BASE5, 10BASE2, 10BASE-T, 100BASE-TX. or 100BASE-FX belong to the shared network That is, the bandwidth of the entire network system system. shared by all nodes in the interconnecting network system. The bandwidth for 10BASE network system is 10MHz, and the bandwidth for 100BASE is 100MHz. Consequently, when the number of nodes in the interconnecting network system exceeds a critical value, the performance of said network system becomes saturated. To overcome this problem, segmenting methodology is employed to segment the entire network system into several independent sub-networks and place each sub-network in a different collision domain. Therefore, nodes connecting to a different sub-network do not share the bandwidth of other sub-networks. For example, if a non-segmented shared 100BASE network system connects 100 nodes, then each node of the fully loaded network shares only 1MHz bandwidth. In contrast, if said shared 100BASE LAN system is segmented into two segments, then each node of loaded network shares 2MHz bandwidth. The segmented LAN employing the Ethernet protocol is called a switching Ethernet. Transmitted packets in different segments are switched by the Ethernet switch. The main I Then the transfer of the tra

5

10

15

20

25

30

Client's ref.:87-188
File: 0492-2480Q/SUE/Final

purpose of the Ethernet switch is to switch the packets to different segments of the LAN; therefore, packets from one segment are delivered to another segment, while packets from a node to another node in the same segment are not delivered.

Associated technology is disclosed in U.S. patents 5,274,631 and 5,491,694.

Fig. 1 is a block diagram illustrating the circuit of the discrete memory structure of the Ethernet switch.

As shown in Fig. 1, the Ethernet switch basically comprises of switch integrated circuit 100 and several port integrated circuits 110a, 110b, and 110c. The switch integrated circuit 100 controls the delivery and switch of network packets among ports. Port integrated circuits 110a, 110b, and 110c comprise internal memories 120a, 120b, and 120c for saving and switching network packets. Under this Ethernet framework, when a network packet is to be transmitted from port 120a to port 130c, the packet has to be first saved in the memory 120a, then transported from the memory 120a to the memory 120c. Therefore, the operating performance of this Ethernet switch is not promising. addition, to enable the links of various LANs, such as 10BASE5, 10BASE2, 10BASE-T, 100BASE-TX, 100BASE-T4, or 100BASE-FX this type of Ethernet switch requires external memory, which is an additional cost.

#### SUMMARY OF THE INVENTION

Accordingly, the primary object of this invention is to provide a switch and method of switching for the Ethernet, for effectively delivering network packets to various segments.

10

15

20

25

30

Client's ref.:87-188 File: 0492-24800/SUE/Final

Another object of this invention is to provide a switch and method of switching for the Ethernet, for linking a 10BASE network system to a 100BASE network system, wherein the existing network system smoothly expands to the new network system.

To realize the above and other objects, this invention provides an Ethernet switch for selectively transporting or The Ethernet switch of this filtering network packets. invention comprises plural network ports, a first and a second memory device, a first and a second memory control devices, an switch device, and a second memory management Network ports are for receiving or delivering network packets. The first memory device saves the source address and associated messages of the network packets. second memory device saves the network packets received from the network port. The first and the second memory control devices connect to the first and the second memory devices, respectively, for controlling the read and write of the first and the second memory devices. Further, the switch device connects the network port and the first memory for creating a source address and the control device, associated messages of the network port for each network packet, and for creating a destination address and the associated messages of the network port for each network packet in accordance with the contents of the first memory device for managing the contents of the first memory device. The second memory device connects the network port and the second memory control device for managing the contents of the second memory device.

Therefore, network packets may be delivered promptly and precisely to the LAN through the routing table initiation

30

5

10

Client's ref.:87-188
File: 0492-2480Q/SUE/Final

module, routing module, learning module and arbitration module. Also, the routing table aging module can reset aged indices periodically, so the indices of the routing table always maintains the most current update.

Moreover, data port can be made uр of independent interface for LANs linking of various specifications. The indices of the routing table comprise source address, address flag, data port number, status, and aged level.

The route aging module can be made up of a countdown timer, its initial value determined by the predetermined life of each index of the routing table, for periodically deducting 1 from the aging index of all indices and resetting the indices with an indexing index less than 1, and for creating the indices for packets of other networks.

The learning module obtains several indices in accordance with the source address of the network packet and the selection mode of the address flag. When a network packet corresponds to one of the indices, the corresponding aging index of said index is set as the initial value. Conversely, when a network packet does not correspond to any index, the aging index with smaller index is then cleared to create a new index corresponding to said packet.

The routing module obtains several indices in accordance with the destination address of the network packet and the selection mode of the address flag. When a network packet corresponds to one of the indices, the data port corresponding to said index then transmits said network packet.

Furthermore, this invention also provides a method of switching network packets for the Ethernet switch, for

25

5

10

Client's ref.:87-188 File: 0492-2480Q/SUE/Final

selectively determining whether to transmit or filter said network packet. Said method comprises the following steps: provide a routing table comprising plural indices, for recording the source address of each packet and the messages associated with said packets. Next, provide a route learning device, for responding to the source address of each packet and the contents of the routing table, and for creating a new index of the routing table or updating an index of the routing table. Further, provide a routing device, for determining the relationship between the destination of each packet and the network port.

#### BRIEF DESCRIPTION OF THE DRAWINGS

The aforementioned objects, features and advantages of this invention will become apparent by referring to the following detailed description of a preferred embodiment with reference to the accompanying drawings, wherein:

Fig. 1 is a block diagram illustrating the circuit of a conventional Ethernet switch with discrete memory framework;

Fig. 2 is a block diagram illustrating the circuit of the Ethernet switch of this invention:

Fig. 3 illustrates the usage allocation of the memory device of the Ethernet switch of this invention;

Fig. 4 illustrates the format of each index in the routing table of the Ethernet switch of this invention;

Fig. 5 is a flowchart illustrating the status of the initiation module of the Ethernet switch of this invention;

Fig. 6 is a flowchart illustrating the status of the aging module of the Ethernet switch of this invention;

25

30

5

10

Client's ref.:87-188
File: 0492-2480Q/SUE/Final

Fig. 7 illustrates the data flow of the destination address and the source address of the Ethernet switch of this invention;

Fig. 8 is a flowchart illustrating the status of the learning module of the Ethernet switch of this invention; and

Fig. 9 is a flowchart illustrating the status of the routing module of the Ethernet switch of this invention.

# DETAILED DESCRIPTION OF THE INVENTION

To realize the above and other objects, this invention provides an Ethernet switch, for selectively transporting or filtering network packets. The Ethernet switch of this type comprises plural network ports, a first and a second memory device, a first and a second memory control devices, a switch device, and a second memory management device. Network ports are for receiving or delivering network The first memory device saves the source address packets. and associated messages of the network packets. memory device saves the network packets received from the network port. The first and the second memory control devices connect to the first and the second memory devices, respectively, for controlling the read and write of the first and the second memory devices. Besides, the switch device connects the network port and the first memory control device, for creating a source address and the associated messages of the network port for each network packet, and for creating a destination address and the associated messages of the network port for each network packet in accordance with the contents of the first memory device for managing the contents of the first memory device.

30

5

10

Client's ref.:87-188
File: 0492-2480Q/SUE/Final

The second memory device connects the network port and the second memory control device for managing the contents of the second memory device. The shared memory access control circuit controls the access to the shared memory device.

An embodiment of this invention is specified in detail with reference to the drawing as follows.

Refer to Fig. 2, a block diagram illustrating the circuit of the Ethernet switch of this invention.

In Fig. 2, an Ethernet switch connecting two LANs comprises: a shared memory device 10, a shared memory access control circuit 20, a data switch module 30, a buffer management unit 50, a buffer table 52, a light emission diode (LED) display 60, an external control interface 70, a routing table 150, and a routing table access control circuit 140, and two data ports 40a and 40b. 40b comprises: media data ports 40a and independent interfaces 41a and 41b, register units 42a and 42b, media access control units 48a and 48b.

[Shared Memory Device 10]

As shown in Fig. 2, the memory device 10 basically serves as the packet buffer 12a. Fig. 3 is a diagram illustrating the memory device 10. In this embodiment, the size of the memory device 10 is 256K words, in units of 1.5K bytes and divided into 341 buffer units. The memory device 10 serves as the packet buffer 12a and is accessible to the data ports 40a and 40b.

[Routing table 150]

Fig. 4 illustrates the format of each index in the routing table 150. Each index takes up four characters in the routing table 150, where the first word comprises a 12-bit ID pattern, a 2-bit age flag (ageflg), a one-bit data

20

25

5

10

Client's ref.:87-188
File: 0492-2480Q/SUE/Final

port number (pno), and a one-bit address flag (flg). The second word is the first to  $16^{\rm th}$  bit of the manufacturer's ID code. The third word is the  $17^{\rm th}$  to the  $24^{\rm th}$  bit of the manufacturer's ID code and a 8-bit age index. The fourth word is reserved.

[Shared Memory Access Control Circuit 20]

As shown in Fig. 2, the shared memory access control circuit 20 basically comprises Arbitrating module 21, Data Multiplexing module 23, Addressing module 25, and command module 27, for controlling the access to the shared memory device 10.

[Routing table Access Control Circuit 140]

As shown in Fig. 2, the routing table access control circuit is responsible for controlling the read and write of the data in the routing table.

[Data Switch module 30]

As shown in Fig. 2, the data switch module 30 basically comprises five modules: Routing Table Initiation module 31, Arbitrating module 33, Routing Table Aging module 35, Routing module 37, and Learning module 39.

Routing table Initiation Module 31

The Routing table Initiation module 31 initializes in two ways: resetting with hardware power and resetting with software programs. Hardware reset generally powers off then on, or decreases then increases the voltage at the reset end of the chip. Software reset is performed by virtue of controlling external interface with software programs.

For example, Routing table Initiation Module 31 clears the age flag and age index of all indices as 0000H.

25

30

5

10

Client's ref.:87-188
File: 0492-2480Q/SUE/Final

Further, Routing table Initiation Module 31 can be interrupted by the external control interface controlled by the software programs.

Fig. 5 is a flowchart illustrating the status of the initiation module 31. As shown in the Figure, there are five states in the routing table initiation module 31: idle IDLE, address reset AddrRst, address index clear EntyClr, last index check LastChk, and address countdown AddrDn.

When the machine is forced to interrupt or the action of the routing table initiation module 31 is completed normally, the routing table initiation module 31 maintains in the idle state; when software control issues a command of controlling the external control interface 70, the routing table initiation module 31 then quits the idle state and enters into the address reset state.

In the address reset state, whether the routing table initiation module 31 is activated by either hardware reset or software, the routing table initiation module 31 first clears the index with the highest address in the routing table 150.

In the address index clear state, the routing table initiation module 31 generates a routing table clear signal for resetting age flag and age index.

In the last index check state, when the index is cleared, said index is checked to determine whether it is the last index on the routing table 150. If yes, then return to idle state; if not, then enter into the address countdown state.

In the address countdown state, the routing table initiation address counter counts down a unit, for continuing the initiation of the index.

30

5

10

Client's ref.:87-188 File: 0492-2480Q/SUE/Final

#### Arbitration Module 33

The arbitration module 33 arbitrates the order of route selection and route learning.

Routing table Aging module 35

In this embodiment, the life of each index in the routing table 150 should be limited to prevent old data from taking up space in the routing table 150. The routing table aging module periodically ages the age index of each index in the routing table 150.

The action of the routing table aging module 35 is driven by the trigger signal of the routing table timer. The trigger signal has a pulse width of 120ns. The clock frequency of the routing table counter is determined by the life span. For example, if the life span is set to one, then the routing table 150 will remove each index after aging for one second; if the life span is set to 100, then the routing table 150 will remove each index after aging for seconds.

In the 25MHz input clock, the 5-bit ripple counter can generate a 781.5KHz clock. The 781.5KHz clock serves as the input clock of the 20-bit countdown timer. The initial value of the countdown timer is the same as the life span; when it counts down to zero, a trigger signal is generated. At the same time, the initial value of the life cycle is reloaded for generating the next trigger signal. Furthermore, the initial value of the life cycle can be set by the external control interface 70 with software.

Each time a trigger signal is generated, 4096 indices of the age index in the routing table 150 is counted down to the next unit. If the life span is set to 2, and all

30

10

Client's ref.:87-188
File: 0492-2480Q/SUE/Final

indices of the age index are set to 191(BFH), then 4096 indices will age and be cleared in almost 2 seconds.

40nsx 32x 2x 4096x 191=2.00278016 seconds

Fig. 6 is a flowchart illustrating the status of the routing table aging module. As shown in the Figure, the routing table aging module 35 has seven states: idle idLE, read age index RdIndx, check age index ChkAlive, age age index WrIndx, address countdown AddrDn, read age flag RdFlag, and write age flag WrFlag.

When aging stops, the routing table aging module 35 maintains in the idle state. When the aging starts or a trigger signal appears, the routing table aging module 35 then quits the idle state and enters into the read age index state.

In the read age index state, the routing table aging module 35 reads the third word in each index of the routing table 150, for obtaining its age index.

After the age index is read, in the check age index state, the attributes of each index in the routing table 150 are checked.

In the degressive age index state, the routing table aging module 35 generates a signal for updating the age index of said index, while the age index counts down to the next unit upon updating.

In the address countdown state, the age address logic circuit will count down the address if the index is accessed.

The age flag represents the attribute of the index. If the attribute of the index survives, then the age flag is 1H. If the attribute of the index aged, then the age flag is 0H. The age flag 2H or 3H indicates that said indices

30

5

10

Client's ref.:87-188
File: 0492-2480Q/SUE/Final

neither aged nor survive. Not all aging processes of each index are required to update the age flag. The routing table aging module 35 will update the age flag only when the age index is counted down from 01H to 00H.

Furthermore, the operation of the data switch module 30 is specified as follows. The operation of the data switch module 30 is basically achieved in accordance with the source address SA and the destination address DA of the network packet and comprises: the routing module 37 and the learning module 39. The learning module 39 is for recording the source address SA and setting the link between the source address SA and the data port. The routing module 37 selects a corresponding data port in accordance with the destination address DA, for outputting said network packet.

Fig. 7 illustrates the data flow of the destination address DA and the source address SA.

In this embodiment, all network packets are received by the receive-direct memory accesses 80a and 80b. The address latch circuit 82a and 82b DASALatch take out the 48-bit destination address DA and the source address SA from the receive-direct memory accesses 80a and 80b. When the latch circuit 82a and 82b DASALatch take out the destination address DA and the source address SA through a route arbitrator 84a, the DA data multiplexer generates a request for route selection and passes through SA route arbitrator 84b, and the SA data multiplexer 86b generates a learning request for activating the selection module 37 of the destination address DA and the source address of the learning module 39, respectively. The access to the routing table 150 of the route selection module 37 and the learning module 39 is made through the memory access

15

25

30

Client's ref.:87-188 File: 0492-2480Q/SUE/Final

arbitrator 90, memory access command control 92, memory address multiplexer 94 and the memory data multiplexer 96. Learning Module 39

of the source address SA learning module 30 performs search and update of the routing table 150. 48-bit source address has two columns: manufacturer's ID and The search on routing table 150 is based serial number. upon the serial number of the source address SA. The 24-bit serial number is in two parts, for serving a respective The search flag defines the index of the routing table. manner of search of the routing table 150. If the 12 bits of the least significant bits of the 24-bit serial number are referred to search the routing table 150, search flag is set to 0. If the 12 bits of the most significant bits of the 24-bit serial number are referred to search the routing table 150, then the search flag is set to To search for an index, three word data will be read, a 8-bit age index, a 24-bit manufacturer's comprising: number, a one-bit network port number, a 1-bit address flag, a two-bit age flag and a 12-bit serial number. The age flag represents the attribute of said index. If the attribute of the index survives, then the age flag is 1H. attribute of the index ages, then the age flag is OH. age flag 2H or 3H indicates that said indices neither age The age index of the surviving index is nor survive. greater than 00H and smaller than COH. The age index of the aged index equals 00H.

The number of the characters of the network port number is contingent upon the number of network ports. embodiment, the number of the characters of the network port number requires only one bit. If the number of the network

10

15

25

30

Client's ref.:87-188
File: 0492-2480Q/SUE/Final

ports is 64, then the network number has to be represented in 6 bits.

A matched index must satisfy the following first conditions:

- (1) the 24-bit manufacturer's ID code equals the  $25^{th}$  to  $48^{th}$  bits of the source address
  - (2) the age index does not equal to 00H and is not larger than  $\ensuremath{\mathtt{BFH}}$ 
    - (3) the age flag equals 1H
  - (4) the network port number equals the network port number for accessing to the corresponding latch circuit of said source address
    - (5) the address flag equals 0
  - (6) the 12-bit serial number equals the 12 bits of the most significant bits of the 24-bit serial number of the source address
    - (7) the search flag equals 0 or the following second conditions:
  - (1) the 24-bit manufacturer's ID code equals the  $25^{\rm th}$  to  $48^{\rm th}$  bits of the source address
  - (2) the age index does not equal to 00H and is not larger than  $\ensuremath{\mathtt{BFH}}$ 
    - (3) the age flag equals 1H
- (4) the network port number equals the network port number for accessing to the corresponding latch circuit of said source address
  - (5) the address flag equals 1
  - (6) the 12-bit serial number equals the 12 bits of the least significant bits of the 24-bit serial number of the source address
    - (7) the search flag equals 1.

30

5

10

Client's ref.:87-188
File: 0492-2480Q/SUE/Final

First, the learning module 39 uses the 12 bits of the least significant bits of the 24-bit serial number as the first index corresponding to the reference in search of the routing table address. Next, three words of said index are read in accordance with said first conditions and it is determined whether it is a matched index. If yes, learning module 39 updates the age index to BFH maintains other data unchanged; otherwise, the learning module 39 searches a second index corresponding to the 12 bits of the most significant bits of the 24-bit serial number in accordance with the source address SA.

Then, as the first index search, three words of the second index are read in accordance with said second conditions and it is determined whether it is a matched index. If yes, the learning module 39 updates the age index to BFH and maintains other data unchanged.

After the two searches, if the learning module 39 still has not found the matched index, the learning module 39 writes the source address data into the index with a smaller index in accordance with the age indices of the first index and the second index.

Fig. 8 illustrates the status of the learning module 39. As shown in the Figure, the learning module 39 comprises the following states: idle IDLE, first search PArouting table 1, second search PArouting table 2, read index RD1W, RD2W, and RD3W, learn LEARN, write index WR1W, WR2W, and WR3W, and done DONE.

The learning module remains idle if no learning request incurs.

In the first search state, the learning module 39 sets the search flag to 0, and the 12 bits of the least

10

15

25

30

Client's ref.:87-188 File: 0492-2480Q/SUE/Final

significant bits of the 24 bit serial number of the source address serves as the search index of the routing table.

In the second search state, the learning module 39 sets the search flag to 1, and the 12 bits of the most significant bits of the 24 bit serial number of the source address serves as the search index of the routing table.

In read index state RD1W, RD2W, and RD3W, the learning module 39 reads the first, the second, and the third words of the search indices, respectively.

In the learning state, the learning determines whether the search indices are matched indices.

In write index state, the learning module 39 writes the first, the second, and the third words of the selected indices, respectively.

The done state is the state after the learning process is completed.

Route Selecting Module 37

The routing selecting module 37 of the destination address DA only performs the routing table 150 searching. The 48-bit destination address DA has two columns: manufacturer's ID and serial number. The search on routing table 150 is based upon the serial number of the destination address DA. The 24-bit serial number is in two parts, for addressing the destination address DA during the search of the routing table 150. The search flag is for the first routing table searching and the second routing If the routing selecting module 37 refers to the searching. 12 bits of the least significant bits of the 24-bit serial number in search of the routing table 150, then the search flag is set to 0. If the routing selecting module 37 refers to the 12 bits of the most significant bits of the 24-bit

30

5

10

Client's ref.:87-188 File: 0492-24800/SUE/Final

serial number in search of the routing table 150, then the search flag is set to 1. After reading each word, the routing selecting module 37 of the destination address checks whether each word is matched. The first word comprises a one-bit input data port number, a one-bit address flag, a two-bit age flag and a 12-bit serial number. The age flag represents the attribute of said index. If the attribute survives, then the age flag is 1H. If the attribute ages, then the age flag is 0H. The age flags 2H and 3H indicate that said indices neither age nor survive.

For a matched index, the first word must satisfy the following first conditions:

- (1) the age flag is 1H
- (2) the address flag is 0
- (3) the 12-bit serial number equals the 12 bits of the most significant bits of the 24-bit serial number of the destination address
  - (4) the search flag equals 0 or the following second conditions:
  - (1) the age flag is 1H
  - (2) the address flag is 1
- (3) the 12-bit serial number equals the 12 bits of the least significant bits of the 24-bit serial number of the destination address
  - (4) the search flag equals 1.

The second word and third word must be compared as in learning module 39.

- (1) the 24-bit manufacturer's ID code equals the  $25^{\rm th}$  to  $48^{\rm th}$  bits of the source address
- (2) the age index does not equal to 00H and is not greater than BFH.

10

15

25

30

Client's ref.:87-188 File: 0492-2480Q/SUE/Final

First, the routing module 37 searches for the first index and reads its first word in accordance with the 12 bits of the least significant bits of the 24-bit serial Next, it is determined whether said index is number. matched in accordance with said first conditions. then take out the network port number from the first word and enter into the done state. If not, the routing module 37 searches for the second index in accordance with the 12 bits of the most significant bits of the 24-bit serial number and determines whether said index is matched in accordance with the said second conditions. If yes, the routing module 37 continues reading the second and the third words of said index and determines whether they are matched. The routing module 37 enters into the done state and resumes the idle state, whether or not the second index is matched.

Fig. 9 is a flowchart illustrating the status of the routing selecting module 37. As shown in the Figure, the routing selecting module 37 comprises the following states: idle IDLE, first search PArouting table 1, second search PArouting table 2, read index RD1W, RD2W, and RD3W, learn index 3WLRN, and done DONE.

The routing module 37 remains idle if no routing request incurs.

In the first search state, the routing module 37 sets the search flag to 0, and the 12 bits of the of the 24 bit serial number significant bits of the destination address serves as the search index of routing table.

In the second search state, the routing module 37 sets the search flag to 1, and the 12 bits of the most significant bits of the 24 bit serial number of the

5

10

Client's ref.:87-188
File: 0492-2480Q/SUE/Final

destination address serves as the search index of the routing table.

In read index state RD1W, RD2W, and RD3W, the routing module 37 reads the first, the second, and the third words of the search indices, respectively.

In the learning state, the learning module 39 determines whether the search indices are matched indices.

In learn index state, the routing module 37 determines whether the first, the second, and the third words of the search indices to be matched, respectively.

The done state is the state after the routing process is completed.

[Network Ports 40a and 40b]

The data ports 40a and 40b can be formed with a media independent interface for linking LANs of various specifications, such as 100BASE and 10BASE LANs.

[Buffer management Unit 50 and Buffer List 52]

The buffer management unit 50a and buffer list 52 manage the memory device 10. The buffer table 52 records the usage status of the memory device 10 through the data ports 40a and 40b and memory interface control device, while the buffer management unit 50 is coupled to the buffer list 52 and accesses to the network packet buffer 12a of the memory device 10 in accordance with all the recorded status in the buffer list 52.

[Light Emission Diode Display Unit 60]

Light emission diode display unit 60 displays the status of the Ethernet switch.

[External Control Interface 70]

30 The external control interface receives external control signals.

10

Client's ref.:87-188
File: 0492-2480Q/SUE/Final

To summarize, this invention provides a switch and method of switching for an Ethernet, for effectively delivering a network packet among segments. The switch of this invention case be used for linking a 10BASE network system to a 100BASE network system for expanding smoothly from the existing network system to the new network system.

Although the present invention has been described in its preferred embodiment, it is not intended to limit the invention to the precise embodiment disclosed herein. Those who are skilled in this technology can still make various alterations and modifications without departing from the scope and spirit of this invention. Therefore, the scope of the present invention shall be defined and protected by the following claims and their equivalents.

3

4

5

6 7

9

10

12

13

18

20

22 23 Client's ref.:87-188 File: 0492-2480Q/SUE/Final

#### WHAT IS CLAIMED IS:

| 1 | 1. | An    | Ethernet | switch | comprising |
|---|----|-------|----------|--------|------------|
| • |    | * *** |          |        |            |

- a plurality of network ports, for receiving or delivering network packets;
- a first memory device, for storing the source address and associated messages of said network packets;
- a second memory device, for storing the data of the network packets received by the network ports;
- a first memory control device, connected to said first memory device, for controlling the read and write of said first memory device;
- a second memory control devices, connected to said second memory device, for controlling the read and write of said second memory device;

an switch device, connected to said plural network ports and said first memory control device, for creating a source address and associated messages of said network ports, creating a destination address and associated messages of said network port for said network packets in accordance with the contents of said first memory device, and managing the contents of said first memory device; and

- a second memory management device, connected to said plural network ports and said second memory control device, for managing the contents of said second memory device.
- 1 2. The Ethernet switch of Claim 1, wherein said network 2 ports comprise a first network port and a second network 3 port.

8

9

10

11

12

13

2

Client's ref.:87-188 File: 0492-24800/SUE/Final

- 3. The Ethernet switch of Claim 1, wherein said network 2 ports comprise media independent interfaces, for connecting 3 to local area networks (LAN) of various specifications.
- 4. The Ethernet switch of Claim 2, wherein said first 2 network port and said second network port comprise media independent interfaces, for connecting to local area network (LAN) of various specifications.
  - 5. The Ethernet switch of Claim 1, wherein said switch device comprises an initiation module, for resetting the contents of said first memory device.
    - 6. The Ethernet switch of Claim 1, wherein said switch device comprises an aging module, for attenuating the expiry of the contents of said first memory device.
    - 7. The Ethernet switch of Claim 1, wherein said switch device comprises

a packet switch routing learning module and a packet switch routing selecting module;

wherein, said packet switch routing learning module searches for the contents of said first memory device in accordance with the source address of said network packets, for creating or updating an index for recording the source addresses of said network packets and their links with said plural network ports; and

said packet switch routing selecting module searches for the contents of said first memory device in accordance with the destination addresses of said network packets, for

2

3

4

5

6

7

8

1

2

Client's ref.:87-188 File: 0492-2480Q/SUE/Final

- obtaining said corresponding network ports, and for 14 15 transporting or filtering said network packets.
- 8. The Ethernet switch of Claim 1, wherein said switch 1 device comprises packet switch processing arbitrating 2 module, for arbitrating the network packet switch processing 3 order of said network packets received from said plural 4 network ports. 5
  - 9. A method of switching network packet for the Ethernet switch, comprising:

providing a routing table made up of plural indices, for recording the source address of said packet and the messages associated with said network port;

providing a route learning device, responding to the source address of said packet and the content of said routing table, for creating a new index of said routing table or updating an index of said routing table; and

providing a route selecting device, responding to the destination address of said packet and the content of said routing table, for determining the link between the destination of said packet and said network port.

- The method of switching packet for the Ethernet switch of Claim 9 further comprising:
- providing a route resetting device, for resetting 3 the content of said routing table. 4
- The method of switching packet for the Ethernet 1 switch of Claim 9 further comprising: 2

8

9

10

11

12 13

14

15

16

2

Client's ref.:87-188
File: 0492-2480Q/SUE/Final

- providing a routing table index expiry attenuatingdevice, for attenuating the content of said routing table.
- 1 12. The method of switching packet for the Ethernet2 switch of Claim 9 further comprising:

providing a route learning and selection

arbitrating device, for arbitrating the network packet

switch processing order of said network packet received from

said plural network port.

13. The method of switching packet for the Ethernet switch of Claim 9 further comprising:

providing an age index, a source port number, an address flag, and an ID pattern in said index.

- 14. The method of switching packet for the Ethernet switch of Claim 9, wherein said route learning device performs the following steps upon creating an index of said routing table or updating an index of said routing table:
- a) set a address flag as the first address flag, set a search index address as the first index address, set an ID pattern as the first ID pattern, set the source network port as the first network port, and set an effective age index range as the first age index range;
- b) read said index in accordance with the first index address on said routing table;
- c) compare the age index of said index to determine whether it is within the range of the first age index;
- d) compare the source network port number, address flag, and ID pattern of said index, to determine whether they are identical to the first network port, the first

2

3

4

5

6

7

8

10

12

14

15

18

19

20

21

22

Client's ref.:87-188 File: 0492-2480Q/SUE/Final

address flag, and the first ID pattern; and 17

- e) determine the source port number of said index 18 and its relation with the source address of said network 19 packet, in response to the outcomes of steps (c) and (d). 20
  - The method of switching packet for the Ethernet switch of Claim 9, wherein said route selecting device performs the following steps upon determining the link between the destination of said packet and said network port:
  - a) set a address flag as the second address flag, set a search index address as the second index address, set an ID pattern as the second ID pattern, set the source network port as the second network port, and set an effective age index range as the second age index range;
  - b) read said index in accordance with the second index address on said routing table;
  - c) compare the age index of said index to determine whether it is within the range of the second age index;
  - d) compare the source network port number, address flag, and ID pattern of said index, to determine whether they are identical to the second network port, the second address flag, and the second ID pattern; and
  - e) determine the source port number of said index and its relation with the destination address of said network packet, in response to the outcomes of steps (c) and (d).

5

10

Client's ref.:87-188
File: 0492-2480Q/SUE/Final

#### ABSTRACT OF THE DISCLOSURE

An Ethernet switch and a method of switch for selectively transporting or filtering network packets. Said Ethernet switch comprises plural network ports, a first and a second memory device, a first and a second memory control device, an switch device, and a second memory management Network ports are for receiving or delivering The first memory device saves the source network packets. address and associated messages of the network packets. second memory device saves the network packets received from the network port. The first and the second memory control devices connect to the first and the second memory devices, respectively, for controlling the read and write of the first and the second memory devices. Further, the switch device connects the network port and the first memory control device, for creating a source address and the associated messages of the network port for each network packet, and for creating a destination address and the associated messages of the network port for each network packet in accordance with the contents of the first memory device for managing the contents of the first memory device. The second memory device connects the network port and the second memory control device for managing the contents of the second memory device. The shared memory access control circuit controls the access to the shared memory device.









| B15 B14 B13 B12 B10 B9 B8 B7 B6 B5 B4 B3 B2 B1 B0 | address flag data port no. age flag | manufacturer ID (I) | age index manufacturer ID (II) | reserved | address flag data port no. age flag |       | age index manufacturer ID (II) | reserved | address flag data port no. age flag | manufacturer ID ( | age index manufacturer ID (II) | reserved | address flag data port no. age flag ID pattern | manufacturer ID (1) | age index manufacturer ID (II) | reserved | address flag data port no. age flag | manufacturer ID (I) | age index manufacturer ID (II) | reserved |
|---------------------------------------------------|-------------------------------------|---------------------|--------------------------------|----------|-------------------------------------|-------|--------------------------------|----------|-------------------------------------|-------------------|--------------------------------|----------|------------------------------------------------|---------------------|--------------------------------|----------|-------------------------------------|---------------------|--------------------------------|----------|
| memory<br>address                                 | H0000                               | 0001H               | 0002H                          | 0003H    | 0004H                               | 0005H | H9000                          | H4000    | H8000                               | H6000             | 000aH                          | 000PH    | H <sup>2</sup> 000                             | HP000               | 000eH                          | 000fH    | 0010H                               | 0011H               | 0012H                          | 0013H    |
| Index                                             | H0000                               |                     |                                |          | 0001H                               |       |                                |          | 0002H                               |                   |                                |          | HE000                                          |                     |                                |          | 0004H                               |                     |                                |          |

FIG. 4



TOP TEAM









FIG. 9

PATENT

#### ATTORNEY DOCKET NO:

# COMBINED DECLARATION AND POWER OF ATTORNEY

As a below named inventor, I hereby declare that:

My residence, post office address and citizenship are as stated below next to my name,

I believe I am the original, first and sole inventor (if only one name is listed below) or an original, first and joint inventor (if plural names are listed below) of the subject matter which is claimed and for which a patent is sought on the invention entitled ETHERNET SWITCH AND METHOD OF SWITCHING

| the specification of whi          |                                                                                          |          |                 |          |                 |                      |  |  |  |  |
|-----------------------------------|------------------------------------------------------------------------------------------|----------|-----------------|----------|-----------------|----------------------|--|--|--|--|
| ■ is attached here □ was filed on |                                                                                          | as Ap    | plication Seri  | al No.   |                 |                      |  |  |  |  |
| and was amend                     | led on                                                                                   |          |                 | • .      |                 |                      |  |  |  |  |
|                                   | ☐ was described and claimed in PCT International Application No.                         |          |                 |          |                 |                      |  |  |  |  |
| filed on                          | and as ame<br>I have reviewed and und                                                    |          | under PCT A     |          |                 | ad specification     |  |  |  |  |
|                                   | amended by any amend                                                                     |          |                 |          | above-identii   | led specification,   |  |  |  |  |
| _                                 |                                                                                          |          |                 |          |                 |                      |  |  |  |  |
|                                   | eduty to disclose all informations, \$1.5                                                |          | on I know to b  | e mater  | ial to patentab | oility in accordance |  |  |  |  |
| application(s) for paten          | eign priority benefits und<br>t or inventor's certificate<br>r inventor's certificate ha | listed   | below and h     | ave also | identified bel  | ow any foreign       |  |  |  |  |
| COUNTRY                           | APPLICATION NO.                                                                          |          | FILING DAT      | E        | PRIORITY        | CLAIMED              |  |  |  |  |
| Taiwan, R.O.C.                    |                                                                                          |          | December        |          |                 | □ No                 |  |  |  |  |
|                                   |                                                                                          |          |                 |          | □Yes            | □ No                 |  |  |  |  |
| Rocky Tsao, Reg. No. 3            | nd Trademark Office con<br>34,053; Frank R. Occhiut<br>one calls to Eric L. Prahl        | i, Reg   | g. No. 35,306.  |          |                 | . 32,590, and Y.     |  |  |  |  |
| Address all corres<br>02110-2804. | spondence to Eric L. Prah                                                                | ıl, Fisi | h & Richardse   | on P.C., | 225 Franklin    | Street, Boston, MA   |  |  |  |  |
| I hereby declare the              | hat all statements made h                                                                | erein    | of my own ki    | nowledg  | e are true and  | that all statements  |  |  |  |  |
| <del>-</del>                      | nd belief are believed to                                                                |          | ·-              | -        |                 |                      |  |  |  |  |
| knowledge that willful            | false statements and the                                                                 | like s   | o made are pu   | mishable | by fine or in   | prisonment, or       |  |  |  |  |
| both, under Section 100           | 01 of Title 18 of the Unit                                                               | ed Sta   | tes Code and    | that suc | h willful false | statements may       |  |  |  |  |
| jeopardize the validity           | of the application or any                                                                | paten    | ts issued there | eon.     |                 | -                    |  |  |  |  |
| Full Name of Inventor;            | Bin Chi CHIOU                                                                            | -        | (Last           | name     | zHIOU)          |                      |  |  |  |  |
| Inventor's Signature              |                                                                                          |          |                 | Date:    | Dec. 27, 1      | 1999                 |  |  |  |  |
|                                   | Same as Post Offi                                                                        | ce A     | ddress (B       | elow)    |                 |                      |  |  |  |  |
| Citizen of: Taiwan,               |                                                                                          |          |                 |          |                 |                      |  |  |  |  |
|                                   | No. 61, Jen-An Tsi                                                                       | ın, F    | (ung-Kuan       | Hsiand   | , Miaoli        | Hsien, Taiwan        |  |  |  |  |
| R.O.C.                            |                                                                                          |          |                 |          |                 |                      |  |  |  |  |
|                                   |                                                                                          |          |                 | Revised  | 1. August 24 1  | 004 (301DECT MD      |  |  |  |  |